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DESCRIPTION 

APPARATUS CONTROL SYSTEM AND METHOD 

The present invention relates to apparatus control systems, in particular 
the present invention relates to user interfaces for mobile telephones. 

Features offered by computer and telephony apparatus are rapidly 
converging. A cheap home computer is now capable of interaction with the 
outside world, in particular, by enabling access to the Internet and the World- 
Wide Web (WWW), whilst telephones are now beginning to offer similar 
connectivity to the outside world. 

Current moves to increase the functionality that mobile telephones offer 
include the introduction of WWW access. Whilst User Interface (Ul) 
components used by the browser are likely to be similar to those used in the Ul 
to control the telephone, the look-and-feel perceived by the user is not 
guaranteed to be equivalent, which is not good usability practice. However, the 
memory and computer processor resources typically available in a mobile 
telephone are limited due to cost, size and weight considerations. In order to 
make the best use of the limited resources, a specific Ul is implemented for 
each mobile telephone type. This is often done at machine code level to take 
best advantage of available resources. By tailoring the Ul application, the 
programmer can implement the Ul to take advantage of any features the 
telephone has whilst avoiding redundant code and features that a generic Ul 
would require in order to support differing mobile telephone models with 
differing feature sets and code bases. Major disadvantages of tailored Ul 
applications include: the time and cost to develop the Ul application each time 
a new telephone is developed; the overheads in maintaining and updating 
each Ul application to fix bugs or support additional telephone hardware or 
telephone network features; and, the individuality of each Ul application given 
that a programmer's style normally impacts on the operation and appearance 
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of the Ul thereby resulting in differences in Ul's in different mobile telephone 
types. 

The WWW has evolved and unified to the extent that there are now well 
defined open standards for client-server communication (typically using the 

5 HyperText Transport Protocol, HTTP), page format (primarily HyperText 
Markup Language, HTML, or an improvement thereon) and underlying 
functionality (commonly implemented in Java, JavaScript, VBScript or Active 
Server Pages). Interactive features of the WWW such as links between pages 
are commonly implemented to have the same appearance across the WWW 

10 due to user expectations of how the link should appear (normally a button or 
underlined Universal Resource Locator (URL) address). However, the WWW 
was primarily intended for full-scale computers, such as PC's, with ample 
memory, fast processor, a permanent storage capacity and keyboard/mouse- 
type input devices. WWW browsers implemented to permit users of PC's to 

15 access the WWW are commonly resource hungry and push the resources of 
many older PC's to the limit. In order to enable users to access the WWW via 
mobile telephones with their limited display area, memory and processors, a 
new type of browser (known as a micro-browser) has been developed 
specifically to run on small devices like mobile telephones. Compared to 

20 fourth-generation browsers (like Netscape v4), micro-browsers have reduced 
capabilities and functionality and are written to transparently interface and use 
existing mobile telephone features to access the WWW using the mobile 
telephone's input device and limiting overall power consumption. 

The connection to the WWW using the mobile telephone presents a 

25 further problem in that wireless data networks tend to have less available 
bandwidth, more latency, less connection stability and less predictable 
availability. Designed with these characteristics in mind, new transport 
protocols have been developed to enable communication between the mobile 
device and the network. One of the first protocols, HDTP (developed by 

30 Unwired Planet), is still in use alongside newer technology specified by the 
WAP Forum. To enable the mobile device to access WWW-content, a 
gateway exists at the mobile telephone provider's receiver which 
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encodes/decodes HTTP traffic into HDTP/WAP traffic and vice-versa. The 
micro-browsers implemented to support these protocols have similar 
limitations to the Ul applications in that the micro-browser must be adapted for 
each new mobile telephone type in order to run on the telephone and to be 
able to control the mobile telephone to make connections to the gateway and 
transmit and receive data. 

Whilst attempts have been made to implement a Ul which operates as a 
micro-browser as well, the micro-browser becomes tied to the mobile 
telephone type in the same way as the Ul applications are. Furthermore, the 
above protocols were not intended to be used to communicate with the rest of 
the mobile telephone, being unable to generate HDML pages dynamically, 
support animations or respond to asynchronous events such as incoming calls. 

According to one aspect of the present invention, there is provided a 
system for controlling an apparatus having a dedicated user interface, parts of 
the dedicated user interface communicating with each other using a dedicated 
user interface message protocol, the system comprising a browser adapted to 
display a generic user interface, to issue requests due to user interaction with 
the generic user interface and to accept notifications comprising data or 
events, and a translation system configured to receive issued requests, to 
translate the requests and to communicate them using the dedicated user 
interface message protocol to one of the parts of the dedicated user interface, 
and to receive communications from the parts of the dedicated user interface 
using the dedicated user interface message protocol, to translate the 
communication into notifications and to pass them to the browser. 

By overlying a browser-based user interface on an existing interface, 
existing web command structure, technology and, most importantly, look and 
feel can be used to provide generic user interfaces. An important aspect of 
the present invention is that the existing user interface remains hidden under 
the browser meaning that a browser-based user interface need not be 
specifically written for each telephone type, the browser need only be adapted 
to communicate with the existing user interface. 
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The browser preferably includes a communications handler configured 
to accept notifications comprising data or events and to issue the requests due 
to user interaction with the generic user interface, wherein the communications 
handler determines the request type and, if the request relates to World Wide 
Web browsing, the communications handler transmits the request to a World 
Wide Web server, otherwise the communications handler passes the request 
to the translation system. 

The browser is preferably a World Wide Web micro-browser. 

The browser may be an HDML micro browser. 

Requests issued due to user interaction with the generic user interface 
may comprise HDML "Get" messages. 

Requests relating to the generic user interface may comprise 
applicative messages embedded within the HDML Get messages. 

The translation system is preferably configured to retrieve the 
applicative message from the HDML Get messages, attach it to an electronic 
delivery envelope determined in dependence on the type of the applicative 
message in accordance with the dedicated user interface message protocol 
and to communicate it to one of the parts of the dedicated user interface. 
Notifications may comprise HDML "x-up-notify" messages. 
Notifications relating to the generic user interface may comprise 
applicative messages embedded within the HDML x-up-notify messages. 

A received communication from the parts of the dedicated user interface 
may comprise one or more applicative messages attached to an electronic 
delivery envelope in accordance with the dedicated user interface message 
protocol, wherein the translation system is configured to retrieve the 
applicative message(s), embed them within an x-up-notify message and pass 
the message to the communications handler. 

The communications handler preferably includes a page generator, 
wherein the communications handler passes received x-up-notify messages to 
the page generator which, in dependence on the embedded applicative 
message(s), generates an HDML page and passes the HDML page within an 
x-up-notify message to the browser for action. 
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Preferably, the apparatus comprises a mobile telephone. 

Preferred embodiments of the present invention will now be described, 
by way of example only, and with reference to the accompanying drawings, in 
5 which: 

Figure 1 is a schematic diagram of a mobile telephone control system 
according to the present invention; 

Figure 2 is a schematic diagram of a specific embodiment of a mobile 
telephone control system in accordance with an aspect of the present 
10 invention; 

Figure 3 is a detailed schematic diagram of parts of the system of 
p Figure 2; 

?j Figure 4 is a diagram of messages used by the mobile telephone 

W control system of Figures 2 and 3; and 

sj is Figure 5 is a schematic diagram of a page generator for use in the 

present invention. 

l=y Figure 1 is a schematic diagram of a mobile telephone control system 

according to the present invention. A mobile telephone 10 includes an 
20 embedded user interface 20 for controlling features of the telephone and for 
interaction with the user via a display area 30 and an input device 40. A micro- 
browser 50 is implemented transparently to the user interface 20 enabling the 
user to access the WWW. A translation unit 60 interfaces the micro-browser 50 
to the user interface 20. A user controls the mobile telephone by entering 
25 commands via the micro-browser 50. The micro-browser 50 is used for all 
user interaction including tasks such as accessing an address book, making a 
telephone call or accessing the World Wide Web. Micro-browser commands 
are processed by the translation unit and translated into corresponding user 
interface commands. Vice-versa, events generated by the mobile telephone 
30 10, such as incoming calls, SMS messages or received WWW pages, are 
notified by the user interface 20 to the translation unit 60. The events are 
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processed by the translation unit 60 and translated into corresponding micro- 
browser events which are passed to the micro-browser 50. 

Figure 2 is a schematic diagram of a specific embodiment of a mobile 
telephone control system in accordance with the present invention. The mobile 
telephone 10 is, for example, a Philips Spark mobile telephone which has a 
user interface 20 defined by an APPI (Application Interface) Message Protocol. 
Applications running on the telephone communicate with and control the 
telephone by sending APPI applicative messages to the APPI. Vice-versa, the 
mobile telephone communicates with applications by sending applicative 
messages from the APPI to the applications. 

A micro-browser 50 implemented using the HDML protocol runs on the 
mobile telephone 10. Messages, requests and events are passed between 
the translation unit 60 and the user interface using applicative messages. In 
this manner, each time the browser 50, or any other on-phone application, 
needs to communicate with the telephone 10, an applicative message is sent 
by the translation unit 60 across the APPI. Using an optional feature of 
applicative messages, data is associated with the messages sent. 

Communication between the micro-browser 50 and the translation unit 
60 is performed using x-up-notify messages 100 from the translation unit 60 to 
the micro-browser 50 and get request messages 120 from the micro-browser 
50 to the translation unit 60. The two message types are defined in the HDTP 
protocol and are discussed further below with reference to Figure 3. 

The micro-browser 50 includes a communications handler 200, 
responsible for transmission and reception of data for the micro-browser 50, 
and an HDML interpreter 205, responsible for user interaction with WWW 
pages on the micro-browser 50 and issuing commands/requests due to user 
interaction. When the micro-browser 50 needs to send events or requests to 
the WWW server (not shown), such as when a WWW page is requested by a 
user, a Get request message is passed to the translation unit 60. A Get 
request message is a PDU (protocol data unit) analogous to the HTTP GET 
method. The message instructs the WWW server to get whatever information 
is associated with a given URL. The HDML interpreter 205 assembles the Get 
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request, including the URL of the requested page, and passes it to the 
communications handler 200. The communications handler identifies the 
standard HDTP Get format and transmits it to the WWW server. 

If, however, the event or request is not a simple request for a WWW 
5 page corresponding to a URL, data associated with the event or request is 
embedded inside a Get request. For example, a WWW page may be 
embedded in the micro-browser 50 allowing the user to enter telephone 
numbers and/or select them from a WWW based telephone book and dial via 
the micro-browser 50. On entering the number, an HDML card (an HDML 
10 micro-browser's version of an HTML page) containing the telephone number 
entered as one or more applicative message is held within the cache of the 
p HDML micro-browser 50. When the user chooses to call the number by, for 

F; example, clicking a call button on the page, the HDML card is read by the 

W HDML micro-browser's interpreter 205 which embeds the applicative 

SJ 15 message(s) into a Get request and passes it to the communications handler 
200 for further action. If, as in the present case, the communications handler 
200 determines that the Get request contains an applicative message and 
should therefore not be transmitted to the WWW server, it passes it to the 
translation unit 60. The translation unit 60 processes the Get request and 
□ 20 transmits across the APPI. 

Examples of applicative messages to be transmitted across the APPI 

may include: 

• APPI_call_setup_req - after manually entering a telephone 
number from the telephone's idle state, a user's request to call 

25 that number results in this message being formatted and 

transmitted across the APPI; 

• APPI_dir_delete_req - When browsing through messages, the 
user is presented with an on-screen menu. Should he select 
delete, this message is formatted and transmitted across the 

30 APPI to perform the required action. 

• When trying to change the ringer type, the user navigates 
through the list of possible ringer types listening to each ringer as 
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it is selected. In this instance, APPI messages are transmitted 
in order to play the next ringer type and also to set the ringer type 
once selected. 

As all browser generated applicative messages are transmitted upon a 

5 keypress or menu selection from an HDML card, all information required to 
form the applicative message is embedded inside the respective HDML card. 
In order to adapt HDML to allow storage of this information, the following tags 
have been expanded: CE and ACTION, relating respectively to data used to 
generate a choice entry in a menu and data associating actions with 

10 keypresses. A command identifier (such as APPI__call_setup_req) and data 
arguments (such as a telephone number) necessary to cause the telephone to 
perform the desired action are added to the above tags. 

When the translation unit 60 is passed a Get message for transmission 
across the APPI, it reads the applicative message content from the Get 

15 message and adds an appropriate envelope so that the APPI message will 
reach the intended destination. Once the envelope is added, the APPI 
message is complete and is transmitted across the APPI triggering actions and 
events at the destination according to the applicative message's content. In 
preparing an envelope for an applicative message for transmission across the 

20 APPI, the following fields are determined and added to the message: 

• length of message (total length of APPI in bytes) 

• orgination address (address of the sender of the APPI message) 

• destination address (address of the recipient of the message - 
this is determined by applicative message's identification field). 

25 The format and an example of an enveloped applicative message is 

shown in Figure 4. 

On-telephone applications communicate via APPI messages by forming 
the necessary applicative message, packaging it up in an envelope and 
transmitting it across the APPI. Events generated at the mobile telephone 10, 

30 such as incoming calls, SMS messages or battery warnings are transmitted 
across the APPI as applicative messages and are intercepted by the 
translation unit 60. Each event is translated into an x-up-notify message which 
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is the means by which HDTP transmits data as and when it becomes 
available, i.e. not in response to a request made (known as the push model). 
The message is then passed to the micro-browser's communications handler 
module. Each message received by the communications handler needs to be 
transformed into an appropriate HDML deck to cause the appropriate events to 
occur in the micro-browser, for example display a prompt on screen and/or to 
play a sound file. The content of the received message is processed 
according to the system of Figure 5. 

Figure 5 is a schematic diagram of a page generator for use in the 
present invention. Messages are passed from the translation unit 60 to the 
communications handler 200. The communications handler 200 processes the 
message to determine whether it relates to an event generated at the mobile 
telephone 10 or it contains a received HDML page. If the message contains a 
received HDML page it is written to the micro-browser's cache 210 for 
subsequent display. If it is determined that the message relates to an event, in 
order to generate an appropriate HDML card corresponding to the message, 
the communications handler 200 passes the message to a page generator 
220. For each message type, the page generator runs an associated script 
230. The script accesses a database 240 which stores command words that 
may be included in the event messages. For each command word, the 
corresponding HDML tag(s) are also stored. The script 230 translates each 
command word into the corresponding HDML tag(s) and creates an 
appropriate HDML card. Actions performed by a script are largely dictated by 
the type and content of the applicative message: for example, an 
APPI_ss_ussd_ind applicative message contains a string of characters to be 
displayed on screen and requires only to be added to a card and formatted. 
However, some applicative messages contain no meaningful content and 
therefore need to be interpreted. For example, having edited a record in a 
telephone book application, the APPI_param_save_cnf message is sent to the 
browser indicating the edited record has been saved correctly. This message 
is translated by the script to trigger an on-screen message that the record was 
saved. Once the HDML card is generated, the page generator 220 passes it 




10 PHB 34441 US 



inside an x-up-notify message to the communications handler 200 which writes 
the message to the micro-browser's cache 210 for subsequent display or 
action by the micro-browser. 

Further areas of standard Ul's not intrinsically supported, or supported 

5 to too limited a level, by micro-browsers are audio menus, Idle state handling 
and Image handling. Audio menus are Ul features where audio associated 
with a menu item is played when browsing the menu. A particular feature of 
audio menus is that the audio is played until a new item in the menu is 
selected or the current menu option is selected. This is done by extending the 

10 CHOICE tag of HDML cards to include a new, non mandatory, boolean 
argument audio_menu which is False by default but True when the choice 
card is being used to represent an audio menu. An applicative message 
instructs the telephone to play the particular audio associated with the tag 
when it is selected and stops the audio if another tag is selected or the current 

15 tag is selected. A mobile telephone is in an idle state when switched on and 
standing by to receive an incoming call or user input. Normally, when in an 
idle state the date, time and name of service provider is displayed. This could 
be done using an HDML display-type card. However, display-type cards 
cannot capture user input. In order to overcome this without resulting to entry- 

20 type cards with their associated prompts, the DISPLAY tag is extended to 
include a boolean argument called idle_state. If this argument is True, a 
keypress causes a transition from the display card to an entry card allowing 
the user to enter a telephone number to be dialed etc. Finally, the HDML IMG 
tag is extended to include halign and valign (horizontal alignment and vertical 

25 alignment respectively) arguments allowing control of an image's position on 
screen. 

It is preferred that APPI messages from on-phone applications are 
intercepted by the translation unit which continuously monitors the APPI. 
However, the applications could be rewritten and explicitly told to direct certain 
30 message types across the APPI to the translation unit. 

Whilst the above description has been primarily concerned with mobile 
telephones, the present invention is also applicable for enabling micro- 
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browsers to be used as user-interfaces for other devices such as remote 
controls, personal data assistants, machinery used on a factory floor or even 
household appliances such as video recorders, microwave ovens and other 
control systems. Equally, the principles of the present invention are applicable 
to many data transmission and display protocols such as WAP (in particular 
WMLscript- WAP's Scripting language) and should not be limited to HDML. 



